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IN THE CLAIMS: 



1 1 . (Currently Amended) A system adapted to distribute redundant information across 

2 disks of an array, the system comprising: 

3 a storage operating system configured to invoke storage operations executed by a 

4 storage system, the storage operating system further configured to manage storage of in- 

5 formation, including the redundant information and data, on blocks of the disks in re- 

6 sponse to disk access operations, the storage operating system including a storage module 

7 adapted to compute the redundant information in response to placement of the data in 

8 stripes across the disks, the storage operating system maintaining at least one unallocated 

9 block per stripe for use by the storage module to store the computed redundant informa- 

10 tion, wherein the at least one unallocated block used to store the redundant information is 
n located in any disk and wherein the location of the at least one unallocated block use used 
12 to store the redundant information can change over time. 



1 2. (Original) The system of Claim 1 wherein the storage module is a disk array controller 

2 configured to compute the redundant information and reconstruct blocks lost due to fail- 

3 ure of one or more of the disks. 



1 3. (Original) The system of Claim 1 wherein the storage module is a RAID system con- 

2 figured to compute the redundant information and reconstruct blocks lost due to failure of 

3 one or more of the disks. 



1 4. (Original) The system of Claim 3 wherein the storage operating system is further con- 

2 figured to implement a high-level module that maintains information about locations of 

3 the data on the disks. 
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1 5. (Original) The system of Claim 4 wherein the high-level module is a file system or da- 

2 tabase adapted to control layout of the data on the disks. 

1 6. (Original)The system of Claim 5 wherein the storage operating system integrates the 

2 file system or database with the RAID system. 

1 7. (Original)The system of Claim 6 wherein the file system or database is configured to 

2 determine block locations of the data on the disks and the RAID system is configured to 

3 determine the block locations of the redundant information on the disks. 

1 8. (Original)The system of Claim 6 wherein the file system or database is configured to 

2 determine block locations of the data and the redundant information on the disks. 

1 9. (Original) The system of Claim 8 wherein the file system or database renders balanc- 

2 ing decisions to determine the block locations of the data and the redundant information 

3 on the disks. 

1 10. (Original) The system of Claim 9 wherein the balancing decisions comprises one of 

2 different sizes of disks, different speeds of disks, and whether a disk is more heavily util- 

3 ized than other disks. 

1 11. (Original) The system of Claim 8 further comprising block allocation map structures 

2 used by the file system to determine the block locations of the data and the redundant in- 

3 formation on the disks. 

i 12. (Original)The system of Claim 1 1 wherein the redundant information is parity. 
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1 13. (Cancelled) 

1 14. (Original) The system of Claim 1 wherein the storage module selects the at least one 

2 unallocated block to store the redundant information and wherein the storage module 

3 computes the redundant information using a redundant storage algorithm. 

1 15. (Original) The system of Claim 14 wherein the selection of the at least one unallo- 

2 cated block to store redundant information is independent of the redundant storage algo- 

3 rithm. 

1 16. (Currently Amended) The system of Claim 15 wherein the redundant storage algo- 

2 rithm is a symmetric algorithm or an asymmetric algorithm . 

l 17. (Original) The system of Claim 16 wherein the redundant information is parity. 

1 18. (Original)The system of Claim 14 wherein the at least one unallocated block used to 

2 store the redundant information comprises two or more unallocated blocks used to store 

3 the redundant information. 

1 19. (Original) The system of Claim 18 wherein the selection of the unallocated blocks to 

2 store redundant information is independent of the redundant storage algorithm used to 

3 compute the redundant information. 

1 20. (Original) The system of Claim 19 wherein the redundant storage algorithm depends 

2 on positions of the blocks in the array. 
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1 21 . (Currently Amended) The system of Claim 20 wherein the redundant storage algo- 

2 rithm is on e of a symmetric and asymmetric algorithm and wherein the redundant infor- 

3 mation is parity. 

1 22. (Currently Amended) A method for distributing redundant information across disks of 

2 an array, the method comprising the steps of: 

3 dividing each disk into blocks, the blocks being organized into stripes such that 

4 each stripe contains one block from each disk; 

5 selecting any blocks in the stripe not used to contain data to contain the redundant 

6 information, wherein the block used to contain the redundant information is located in 

7 any disk and wherein the location of the block use used to contain the redundant informa- 

8 tion can change over time; and 

9 computing the redundant information based on contents of all other blocks in the 

10 stripe, regardless of whether the blocks contain data. 

1 23. (Original)The method of Claim 22 further comprising the step of determining which 

2 block in a stripe contains redundant information each time there is a write request to the 

3 stripe. 

1 24. (Original)The method of Claim 23 further comprising the step of assigning a block to 

2 contain redundant information when each stripe is written. 

1 25. (Original) The method of Claim 24 wherein the step of determining is performed by a 

2 high-level module of a storage system and wherein the steps of computing and assigning 

3 are performed by a storage module of the storage system. 

i 26. (Original) The method of Claim 25 further comprising the steps of: 
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2 maintaining, by the high-level module, at least one unallocated block per stripe 

3 for use by the storage module; and 

4 providing an indication from the high-level module to the storage module of the 

5 unallocated block to contain parity. 

1 27. (Original) The method of Claim 26 further comprising the step of reconstructing, us- 

2 ing the storage module, a block that is lost due to failure of a disk. 

1 28. (Original) The method of Claim 25 wherein the high-level module is a file system and 

2 wherein the storage module is one of an array controller and a RAID system. 

1 29. (Original) The method of Claim 28 wherein the step of computing comprises the step 

2 of computing the redundant information in response to placement of the data in stripes 

3 across the disks. 

1 30. (Original) The method of Claim 29 wherein the step of computing further comprises 

2 the step of computing the redundant information using algebraic and algorithmic calcula- 

3 tions in response to the placement of the data on the array. 

1 31. (Currently Amended) Apparatus for distributing redundant information across disks 

2 of an array, the apparatus comprising: 

3 means for dividing each disk into stripes, with each stripe containing one block 

4 from each disk; 

5 means for selecting any blocks in the stripe not used to contain data to contain re- 

6 dundant information, wherein the block used to contain the redundant information is lo- 

7 cated in any disk and wherein the location of the block use used to contain the redundant 

8 information can change over time; and 
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9 means for computing the redundant information based on contents of all other 

10 blocks in the stripe, regardless of whether the blocks contain data. 

1 32. (Original) The apparatus of Claim 3 1 further comprising means for determining 

2 which block or blocks in a stripe holds redundant information each time there is a write 

3 operation to the stripe. 

1 33. (Currently Amended) A computer readable medium containing executable program 

2 instructions for distributing parity across disks of an array, the executable instructions 

3 comprising one or more program instructions for: 

4 dividing each disk into stripes, with each stripe containing one block from each 

5 disk; 

6 selecting any blocks in the stripe not used to contain data to contain parity, 

7 wherein the block used to contain the parity is located in any disk and wherein the loca- 

8 tion of the block use used to contain the parity can change over time; and 

9 computing the parity based on contents of all other blocks in the stripe, regardless 

10 of whether the blocks contain data. 
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Please add new claims 34 et al 

34. (New) The system of Claim 15 wherein the redundant storage algorithm is an asym- 
metric algorithm 

35. (New) The system of Claim 20 wherein the redundant storage algorithm is an asym- 
metric algorithm and wherein the redundant information is parity. 

36. (New) A method for distributing redundant information across disks of an array with 
a plurality of blocks on each disk, comprising: 

determining which blocks are unallocated in a strip across the disks; 

reserving unallocated blocks for storing the redundant information in one or more 
reserved unallocated blocks; 

arranging data in the stripe for the data to be stored in one or more allocated 
blocks across the disks of the array; 

assigning the redundant information to the one or more reserved unallocated 
blocks; and 

writing the data in the allocated blocks and the redundant information in the one 
or more reserved unallocated blocks as the stripe across the disks of the array. 

37. (New) The method of claim 36, further comprising: 
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2 storing parity information as the redundant information in the one or more re- 

3 served unallocated blocks. 

1 38. (New) The method of claim 36, further comprising: 

2 adding a disk to the array; 

3 storing a second stripe across the array by determining one or more unallocated 

4 blocks across the array including the added disk, and writing the data to allocated blocks 

5 and the redundant information to the one or more unallocated blocks of the second stripe. 

1 39. (New) An apparatus for distributing redundant information across disks of an array 

2 with a plurality of blocks on each disk, comprising: 



3 means for determining which blocks are unallocated in a strip across the disks; 

4 means for reserving unallocated blocks for storing the redundant information in 

5 one or more reserved unallocated blocks; 

6 means for arranging data in the stripe for the data to be stored in one or more alio- 

7 cated blocks across the disks of the array; 

8 means for assigning the redundant information to the one or more reserved unal- 

9 located block; and 

10 means for writing the data in the allocated blocks and the redundant information 

11 in the one or more reserved unallocated blocks as the stripe across the disks of the array. 



l 40. (New) The apparatus of claim 39, further comprising: 
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means for storing parity information as the redundant information in the one or 
more reserved unallocated blocks. 

41. (New) The apparatus of claim 39, further comprising: 

means for adding a disk to the array; 

means for storing a second stripe across the array by determining one or more un- 
allocated blocks across the array including the added disk, and writing the data to allo- 
cated blocks and the redundant information to the one or more unallocated blocks of the 
second stripe. 

42. (New) A system for distributing redundant information across disks of an array with a 
plurality of blocks on each disk, comprising: 

a storage operating system configured to invoke storage operations executed by a 
storage system, the storage operating system further configured (i) to determine which 
blocks are unallocated in a strip across the disks, (ii) to reserve unallocated blocks for 
storing the redundant information in one or more reserved unallocated blocks, (iii) to ar- 
range data in the stripe for the data to be stored in one or more allocated blocks across the 
disks of the array, (iv) to assign the redundant information to the one or more reserved 
unallocated block, and (iv) to write the data in the allocated blocks and the redundant in- 
formation in the one or more reserved unallocated blocks as the stripe across the disks of 
the array. 
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43. (New) The system of claim 42, wherein the redundant information is parity informa- 
tion. 

44. (New) A computer readable medium containing executable program instructions for 
distributing parity across disks of an array, the executable instructions comprising one or 
more program instructions for: 

determining which blocks are unallocated in a strip across the disks, where each 
disk has a plurality of blocks; 

reserving unallocated blocks for storing the redundant information in one or more 
reserved unallocated blocks; 

arranging data in the stripe for the data to be stored in one or more allocated 
blocks across the disks of the array; and 

assigning the redundant information to the one or more reserved unallocated 
block; and 

writing the data in the allocated blocks and the redundant information in the one 
or more reserved unallocated blocks as the stripe across the disks of the array 
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